<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>转盘抽奖 - wazanHub</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="wazan" /><meta name="description" content="好的项目逻辑开发要记下备用
疫情期间，销售拉单“无底线”，产品策划很“无限”，各种活动满足米饭班主。
这是做过的在线最久的活动，最初开始做是4月完成的一版，现在也没下线。
项目由我们这边开发完成，然后提供html（外链了上传到我们服务器的各种资源）给某祺汽车的官网老师上传到他们服务器生成他们域名的链接。
活动地址 线上链接：传祺GS4 3999出行补贴天天抽
线下链接：传祺GS4 3999出行补贴天天抽
总体需求  填写信息留资成功即可参加抽奖 每个号码有3次抽奖机会(转3次转盘) 奖品为不同类型的券的兑换码  开发思路 分为2个页面  首页index.html 活动页main.html
其中活动页的业务显然很多，这里采用了分为不同页面层显示隐藏的模式，类似于vue的单页面开发。具体可分为：
报名页模块
转盘抽奖页模块
奖品选择领取页模块
已领取兑换码展示页模块  将这些模块都写在main.html里再通过显示隐藏来实现，选择这样开发有优缺点
优点：
1.对每个模块的关联数据更加方便处理，降低开发难度（不然只能通过url去传递关联数据，相比之下vue的路由传参和vuex就能体现场景优势）
2.而且能减少不同页面跳转带来切换不流畅的不良体验，和减少不同机型在切换时出现的一些兼容问题
缺点： 1.全部图片样式资源写在main.html里必然造成请求和加载量多。只能通过尽量使用公共背景图片或者制作雪碧图等优化
2.全部页面逻辑写在一个页面，必然造成不同模块逻辑的相互影响
转盘抽奖页模块 html、js分离整理 别看只有3次抽奖，但注意业务逻辑还真不少，比如：
 没抽奖前该显示什么， 每抽完一次要显示的结果是什么，文案要合理 没用完3次机会前退出或者刷新页面需要带来的变化 机会用完时该怎样处理 &amp;hellip;
当时想到了分离html、js的做法， 1.先把html部分不同情况的抽奖结果模块化写出来，  &amp;lt;!-- 还没开始抽 --&amp;gt; &amp;lt;div class=&amp;#34;result start&amp;#34;&amp;gt; &amp;lt;p class=&amp;#34;txt3&amp;#34;&amp;gt;&amp;lt;span class=&amp;#34;licon&amp;#34;&amp;gt;&amp;lt;/span&amp;gt;您有&amp;lt;b class=&amp;#34;remainTimes&amp;#34;&amp;gt;0&amp;lt;/b&amp;gt;次抽奖机会&amp;lt;span class=&amp;#34;ricon&amp;#34;&amp;gt;&amp;lt;/span&amp;gt;&amp;lt;/p&amp;gt; &amp;lt;/div&amp;gt; &amp;lt;!-- 中奖还有机会，继续抽 --&amp;gt; &amp;lt;div class=&amp;#34;result prize-again&amp;#34;&amp;gt; &amp;lt;p class=&amp;#34;txt1&amp;#34;&amp;gt;恭喜您获得：&amp;lt;/p&amp;gt; &amp;lt;p class=&amp;#34;txt2&amp;#34;&amp;gt;&amp;lt;/p&amp;gt; &amp;lt;p class=&amp;#34;txt3&amp;#34;&amp;gt;&amp;lt;span class=&amp;#34;licon&amp;#34;&amp;gt;&amp;lt;/span&amp;gt;您还有&amp;lt;b class=&amp;#34;remainTimes&amp;#34;&amp;gt;0&amp;lt;/b&amp;gt;次抽奖机会&amp;lt;span class=&amp;#34;ricon&amp;#34;&amp;gt;&amp;lt;/span&amp;gt;&amp;lt;/p&amp;gt; &amp;lt;div class=&amp;#34;btn_again play&amp;#34;&amp;gt;&amp;lt;/div&amp;gt; &amp;lt;/div&amp;gt; &amp;lt;!" /><meta name="keywords" content="wazan, study" />






<meta name="generator" content="Hugo 0.70.0 with theme even" />


<link rel="canonical" href="http://wazan.gitee.io/blog/post/t-%E8%BD%AC%E7%9B%98%E6%8A%BD%E5%A5%96/" />
<link rel="apple-touch-icon" sizes="180x180" href="/blog/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/blog/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/blog/favicon-16x16.png">
<link rel="manifest" href="/blog/manifest.json">
<link rel="mask-icon" href="/blog/safari-pinned-tab.svg" color="#5bbad5">



<link href="/blog/sass/main.min.b70575932d58f00331c6aacffef9d6f69bd146e84ff98ee769622d3439951b79.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="转盘抽奖" />
<meta property="og:description" content="好的项目逻辑开发要记下备用
疫情期间，销售拉单“无底线”，产品策划很“无限”，各种活动满足米饭班主。
这是做过的在线最久的活动，最初开始做是4月完成的一版，现在也没下线。
项目由我们这边开发完成，然后提供html（外链了上传到我们服务器的各种资源）给某祺汽车的官网老师上传到他们服务器生成他们域名的链接。
活动地址 线上链接：传祺GS4 3999出行补贴天天抽
线下链接：传祺GS4 3999出行补贴天天抽
总体需求  填写信息留资成功即可参加抽奖 每个号码有3次抽奖机会(转3次转盘) 奖品为不同类型的券的兑换码  开发思路 分为2个页面  首页index.html 活动页main.html
其中活动页的业务显然很多，这里采用了分为不同页面层显示隐藏的模式，类似于vue的单页面开发。具体可分为：
报名页模块
转盘抽奖页模块
奖品选择领取页模块
已领取兑换码展示页模块  将这些模块都写在main.html里再通过显示隐藏来实现，选择这样开发有优缺点
优点：
1.对每个模块的关联数据更加方便处理，降低开发难度（不然只能通过url去传递关联数据，相比之下vue的路由传参和vuex就能体现场景优势）
2.而且能减少不同页面跳转带来切换不流畅的不良体验，和减少不同机型在切换时出现的一些兼容问题
缺点： 1.全部图片样式资源写在main.html里必然造成请求和加载量多。只能通过尽量使用公共背景图片或者制作雪碧图等优化
2.全部页面逻辑写在一个页面，必然造成不同模块逻辑的相互影响
转盘抽奖页模块 html、js分离整理 别看只有3次抽奖，但注意业务逻辑还真不少，比如：
 没抽奖前该显示什么， 每抽完一次要显示的结果是什么，文案要合理 没用完3次机会前退出或者刷新页面需要带来的变化 机会用完时该怎样处理 &hellip;
当时想到了分离html、js的做法， 1.先把html部分不同情况的抽奖结果模块化写出来，  &lt;!-- 还没开始抽 --&gt; &lt;div class=&#34;result start&#34;&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;/div&gt; &lt;!-- 中奖还有机会，继续抽 --&gt; &lt;div class=&#34;result prize-again&#34;&gt; &lt;p class=&#34;txt1&#34;&gt;恭喜您获得：&lt;/p&gt; &lt;p class=&#34;txt2&#34;&gt;&lt;/p&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您还有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;div class=&#34;btn_again play&#34;&gt;&lt;/div&gt; &lt;/div&gt; &lt;!" />
<meta property="og:type" content="article" />
<meta property="og:url" content="http://wazan.gitee.io/blog/post/t-%E8%BD%AC%E7%9B%98%E6%8A%BD%E5%A5%96/" />
<meta property="article:published_time" content="2020-06-29T14:28:13+08:00" />
<meta property="article:modified_time" content="2020-06-29T14:28:13+08:00" />
<meta itemprop="name" content="转盘抽奖">
<meta itemprop="description" content="好的项目逻辑开发要记下备用
疫情期间，销售拉单“无底线”，产品策划很“无限”，各种活动满足米饭班主。
这是做过的在线最久的活动，最初开始做是4月完成的一版，现在也没下线。
项目由我们这边开发完成，然后提供html（外链了上传到我们服务器的各种资源）给某祺汽车的官网老师上传到他们服务器生成他们域名的链接。
活动地址 线上链接：传祺GS4 3999出行补贴天天抽
线下链接：传祺GS4 3999出行补贴天天抽
总体需求  填写信息留资成功即可参加抽奖 每个号码有3次抽奖机会(转3次转盘) 奖品为不同类型的券的兑换码  开发思路 分为2个页面  首页index.html 活动页main.html
其中活动页的业务显然很多，这里采用了分为不同页面层显示隐藏的模式，类似于vue的单页面开发。具体可分为：
报名页模块
转盘抽奖页模块
奖品选择领取页模块
已领取兑换码展示页模块  将这些模块都写在main.html里再通过显示隐藏来实现，选择这样开发有优缺点
优点：
1.对每个模块的关联数据更加方便处理，降低开发难度（不然只能通过url去传递关联数据，相比之下vue的路由传参和vuex就能体现场景优势）
2.而且能减少不同页面跳转带来切换不流畅的不良体验，和减少不同机型在切换时出现的一些兼容问题
缺点： 1.全部图片样式资源写在main.html里必然造成请求和加载量多。只能通过尽量使用公共背景图片或者制作雪碧图等优化
2.全部页面逻辑写在一个页面，必然造成不同模块逻辑的相互影响
转盘抽奖页模块 html、js分离整理 别看只有3次抽奖，但注意业务逻辑还真不少，比如：
 没抽奖前该显示什么， 每抽完一次要显示的结果是什么，文案要合理 没用完3次机会前退出或者刷新页面需要带来的变化 机会用完时该怎样处理 &hellip;
当时想到了分离html、js的做法， 1.先把html部分不同情况的抽奖结果模块化写出来，  &lt;!-- 还没开始抽 --&gt; &lt;div class=&#34;result start&#34;&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;/div&gt; &lt;!-- 中奖还有机会，继续抽 --&gt; &lt;div class=&#34;result prize-again&#34;&gt; &lt;p class=&#34;txt1&#34;&gt;恭喜您获得：&lt;/p&gt; &lt;p class=&#34;txt2&#34;&gt;&lt;/p&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您还有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;div class=&#34;btn_again play&#34;&gt;&lt;/div&gt; &lt;/div&gt; &lt;!">
<meta itemprop="datePublished" content="2020-06-29T14:28:13&#43;08:00" />
<meta itemprop="dateModified" content="2020-06-29T14:28:13&#43;08:00" />
<meta itemprop="wordCount" content="239">



<meta itemprop="keywords" content="项目总结," /><meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="转盘抽奖"/>
<meta name="twitter:description" content="好的项目逻辑开发要记下备用
疫情期间，销售拉单“无底线”，产品策划很“无限”，各种活动满足米饭班主。
这是做过的在线最久的活动，最初开始做是4月完成的一版，现在也没下线。
项目由我们这边开发完成，然后提供html（外链了上传到我们服务器的各种资源）给某祺汽车的官网老师上传到他们服务器生成他们域名的链接。
活动地址 线上链接：传祺GS4 3999出行补贴天天抽
线下链接：传祺GS4 3999出行补贴天天抽
总体需求  填写信息留资成功即可参加抽奖 每个号码有3次抽奖机会(转3次转盘) 奖品为不同类型的券的兑换码  开发思路 分为2个页面  首页index.html 活动页main.html
其中活动页的业务显然很多，这里采用了分为不同页面层显示隐藏的模式，类似于vue的单页面开发。具体可分为：
报名页模块
转盘抽奖页模块
奖品选择领取页模块
已领取兑换码展示页模块  将这些模块都写在main.html里再通过显示隐藏来实现，选择这样开发有优缺点
优点：
1.对每个模块的关联数据更加方便处理，降低开发难度（不然只能通过url去传递关联数据，相比之下vue的路由传参和vuex就能体现场景优势）
2.而且能减少不同页面跳转带来切换不流畅的不良体验，和减少不同机型在切换时出现的一些兼容问题
缺点： 1.全部图片样式资源写在main.html里必然造成请求和加载量多。只能通过尽量使用公共背景图片或者制作雪碧图等优化
2.全部页面逻辑写在一个页面，必然造成不同模块逻辑的相互影响
转盘抽奖页模块 html、js分离整理 别看只有3次抽奖，但注意业务逻辑还真不少，比如：
 没抽奖前该显示什么， 每抽完一次要显示的结果是什么，文案要合理 没用完3次机会前退出或者刷新页面需要带来的变化 机会用完时该怎样处理 &hellip;
当时想到了分离html、js的做法， 1.先把html部分不同情况的抽奖结果模块化写出来，  &lt;!-- 还没开始抽 --&gt; &lt;div class=&#34;result start&#34;&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;/div&gt; &lt;!-- 中奖还有机会，继续抽 --&gt; &lt;div class=&#34;result prize-again&#34;&gt; &lt;p class=&#34;txt1&#34;&gt;恭喜您获得：&lt;/p&gt; &lt;p class=&#34;txt2&#34;&gt;&lt;/p&gt; &lt;p class=&#34;txt3&#34;&gt;&lt;span class=&#34;licon&#34;&gt;&lt;/span&gt;您还有&lt;b class=&#34;remainTimes&#34;&gt;0&lt;/b&gt;次抽奖机会&lt;span class=&#34;ricon&#34;&gt;&lt;/span&gt;&lt;/p&gt; &lt;div class=&#34;btn_again play&#34;&gt;&lt;/div&gt; &lt;/div&gt; &lt;!"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/blog/" class="logo">wazanHub</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/blog/">
        <li class="mobile-menu-item">首页</li>
      </a><a href="/blog/post/">
        <li class="mobile-menu-item">归档</li>
      </a><a href="/blog/tags/">
        <li class="mobile-menu-item">标签</li>
      </a><a href="/blog/categories/">
        <li class="mobile-menu-item">分类</li>
      </a><a href="/blog/about/">
        <li class="mobile-menu-item">关于</li>
      </a>
  </ul>
</nav>
  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/blog/" class="logo">wazanHub</a>
</div>

<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/blog/">首页</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/post/">归档</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/tags/">标签</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/categories/">分类</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/about/">关于</a>
      </li>
  </ul>
</nav>
    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <article class="post">
    
    <header class="post-header">
      <h1 class="post-title">转盘抽奖</h1>

      <div class="post-meta">
        <span class="post-time"> 2020-06-29 </span>
        <div class="post-category">
            <a href="/blog/categories/%E9%A1%B9%E7%9B%AE/"> 项目 </a>
            </div>
        
      </div>
    </header>

    <div class="post-toc" id="post-toc">
  <h2 class="post-toc-title">文章目录</h2>
  <div class="post-toc-content always-active">
    <nav id="TableOfContents">
  <ul>
    <li><a href="#活动地址">活动地址</a></li>
    <li><a href="#总体需求">总体需求</a></li>
    <li><a href="#开发思路">开发思路</a>
      <ul>
        <li><a href="#分为2个页面-">分为2个页面</a></li>
      </ul>
    </li>
    <li><a href="#转盘抽奖页模块">转盘抽奖页模块</a>
      <ul>
        <li><a href="#htmljs分离整理-">html、js分离整理</a></li>
      </ul>
    </li>
    <li><a href="#添加验证码">添加验证码</a></li>
    <li><a href="#资源">资源</a></li>
  </ul>
</nav>
  </div>
</div>
    <div class="post-content">
      <p><strong><code>好的项目逻辑开发要记下备用</code></strong></p>
<p><!-- raw HTML omitted --> <!-- raw HTML omitted -->
疫情期间，销售拉单“无底线”，产品策划很“无限”，各种活动满足米饭班主。<br>
这是做过的在线最久的活动，最初开始做是4月完成的一版，现在也没下线。</p>
<p>项目由我们这边开发完成，然后提供html（外链了上传到我们服务器的各种资源）给某祺汽车的官网老师上传到他们服务器生成他们域名的链接。</p>
<h2 id="活动地址">活动地址</h2>
<p>线上链接：<a href="https://www.gacmotor.com/activity2020/index.html">传祺GS4 3999出行补贴天天抽</a><br>
线下链接：<a href="https://www.gacmotor.com/activity2020gift/">传祺GS4 3999出行补贴天天抽</a></p>
<p><!-- raw HTML omitted --> <!-- raw HTML omitted --></p>
<h2 id="总体需求">总体需求</h2>
<ul>
<li>填写信息留资成功即可参加抽奖</li>
<li>每个号码有3次抽奖机会(转3次转盘)</li>
<li>奖品为不同类型的券的兑换码</li>
</ul>
<p><!-- raw HTML omitted --> <!-- raw HTML omitted --></p>
<h2 id="开发思路">开发思路</h2>
<h3 id="分为2个页面-">分为2个页面</h3>
<ul>
<li>首页index.html</li>
<li>活动页main.html<br>
其中活动页的业务显然很多，这里采用了分为不同页面层显示隐藏的模式，类似于vue的单页面开发。具体可分为：<br>
<code>报名页模块</code><br>
<code>转盘抽奖页模块</code><br>
<code>奖品选择领取页模块</code><br>
<code>已领取兑换码展示页模块</code></li>
</ul>
<p>将这些模块都写在main.html里再通过显示隐藏来实现，选择这样开发有优缺点<br>
<strong>优点：</strong><br>
1.对每个模块的关联数据更加方便处理，降低开发难度（不然只能通过url去传递关联数据，相比之下vue的路由传参和vuex就能体现场景优势）<br>
2.而且能减少不同页面跳转带来切换不流畅的不良体验，和减少不同机型在切换时出现的一些兼容问题<br>
<strong>缺点：</strong> <br>
1.全部图片样式资源写在main.html里必然造成请求和加载量多。只能通过尽量使用公共背景图片或者制作雪碧图等优化<br>
2.全部页面逻辑写在一个页面，必然造成不同模块逻辑的相互影响</p>
<p><!-- raw HTML omitted --> <!-- raw HTML omitted --></p>
<h2 id="转盘抽奖页模块">转盘抽奖页模块</h2>
<p><img src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/b4e52ccdeeca4f29ae77d2e3dfbbad57~tplv-k3u1fbpfcp-zoom-1.image" alt=""></p>
<h3 id="htmljs分离整理-">html、js分离整理</h3>
<p>别看只有3次抽奖，但注意业务逻辑还真不少，比如：</p>
<ul>
<li>没抽奖前该显示什么，</li>
<li>每抽完一次要显示的结果是什么，文案要合理</li>
<li>没用完3次机会前退出或者刷新页面需要带来的变化</li>
<li>机会用完时该怎样处理</li>
<li>&hellip;<br>
当时想到了分离html、js的做法， <br>
1.先把html部分不同情况的抽奖结果模块化写出来，</li>
</ul>
<div class="highlight"><pre style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-html" data-lang="html">    <span style="color:#75715e">&lt;!-- 还没开始抽 --&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result start&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;您有&lt;<span style="color:#f92672">b</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;remainTimes&#34;</span>&gt;0&lt;/<span style="color:#f92672">b</span>&gt;次抽奖机会&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;

    <span style="color:#75715e">&lt;!-- 中奖还有机会，继续抽 --&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result prize-again&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt1&#34;</span>&gt;恭喜您获得：&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt2&#34;</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;您还有&lt;<span style="color:#f92672">b</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;remainTimes&#34;</span>&gt;0&lt;/<span style="color:#f92672">b</span>&gt;次抽奖机会&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;btn_again play&#34;</span>&gt;&lt;/<span style="color:#f92672">div</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;

    <span style="color:#75715e">&lt;!-- 不中奖还有机会，继续抽--&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result noprize-again&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt2&#34;</span>&gt;很遗憾，你未中奖&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;您还有&lt;<span style="color:#f92672">b</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;remainTimes&#34;</span>&gt;0&lt;/<span style="color:#f92672">b</span>&gt;次抽奖机会&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;btn_again play&#34;</span>&gt;&lt;/<span style="color:#f92672">div</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;



    <span style="color:#75715e">&lt;!-- 中奖没有机会了--&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result prize-end&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt1&#34;</span>&gt;恭喜您获得：&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt2&#34;</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;机会已用完，请点击上方&#34;我的奖品&#34;领取奖励&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;

    <span style="color:#75715e">&lt;!-- 没中奖没有机会了--&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result noprize-end&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt2&#34;</span>&gt;很遗憾，你未中奖&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;机会已用完，请点击上方&#34;我的奖品&#34;领取奖励&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;

    <span style="color:#75715e">&lt;!-- 再次进来没有机会了--&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result end&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;机会已用完&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;

    <span style="color:#75715e">&lt;!-- 再次进来还有机会了--&gt;</span>
    &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;result no-end&#34;</span>&gt;
      &lt;<span style="color:#f92672">p</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;txt3&#34;</span>&gt;&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;licon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;您还有&lt;<span style="color:#f92672">b</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;remainTimes&#34;</span>&gt;0&lt;/<span style="color:#f92672">b</span>&gt;次抽奖机会&lt;<span style="color:#f92672">span</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;ricon&#34;</span>&gt;&lt;/<span style="color:#f92672">span</span>&gt;&lt;/<span style="color:#f92672">p</span>&gt;
      &lt;<span style="color:#f92672">div</span> <span style="color:#a6e22e">class</span><span style="color:#f92672">=</span><span style="color:#e6db74">&#34;btn_again play&#34;</span>&gt;&lt;/<span style="color:#f92672">div</span>&gt;
    &lt;/<span style="color:#f92672">div</span>&gt;
</code></pre></div><p>2.然后再在js里对不同的情况做下判断处理每次将这些模块化显示影藏</p>
<p>这种做法明显会让你更快地搞清楚逻辑需求，明确自己的开发步骤，尤其在后面还有其他关联业务减少混乱，避免不同情况缺少这个那个文案，按钮之类</p>
<p><!-- raw HTML omitted --> <!-- raw HTML omitted --></p>
<h2 id="添加验证码">添加验证码</h2>
<p>活动上线之后发现有人故意刷数据，决定提高参与门槛<br>
首先从后端搬来短信验证码，后来发现这样也不行，这个h5活动没有账号密码限制要防刷实在太难，短信验证也可以被恶意输入任意号码去调接口，每条短信都是需要money的，<br>
<code>图片证码+短信验证码</code><br>
<img src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/91e01265d4ad4c009e1e8fc21f44493d~tplv-k3u1fbpfcp-zoom-1.image" alt="">
<img src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d0c4cf85b58646cfa4ecc2dfdfd81a48~tplv-k3u1fbpfcp-zoom-1.image" alt=""></p>
<p>最后商量决定先加图形验证码，图形验证成功再允许调取短信接口
<img src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a733defe63c4452e9e0f27827fdf748f~tplv-k3u1fbpfcp-zoom-1.image" alt=""></p>
<p><strong>注意点：</strong>
这里是直接src去请求图片验证码，如果是看不清等情况的验证码还要点击能获取新的，这里给src图片请求后面加上个时间戳，这样才会再次去请求返回验证码</p>
<pre><code>    getPic: function(fn) {
      $('.ycode').val('');
      var time=new Date().getTime();
      var purl=&quot;//play9.pcauto.com.cn/auto200165/api/auth/validateCode.do?phone=&quot;+$('.i2').val()+'&amp;time='+time;
      $('.ypic').html('&lt;img src='+purl+'/&gt;');
  },
</code></pre><p>这里还给获取图形验证码的按钮加个1min的延时，如果请求获取短信验证码的1min里不能请求</p>
<p><img src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3850e9747dab45aa8ddde40c7fb28f43~tplv-k3u1fbpfcp-zoom-1.image" alt=""></p>
<pre><code>getMessageCaptcha: function() {
      $.ajax({
          url: comm.action + 'getMessageCaptcha.jsp',
          type: 'POST',
          data: {
              ischeck: false,
              phone: $('.i2').val(),
              keyCode:$('.ycode').val()
          },
          xhrFields: {
              withCredentials: true
          },
          success: function(data) {
              if (data.code == 1) {
                  $('.ybox').hide();
                  $('.fixed1').hide();

                  $('.ybtn').hide();
                  $('.un-ybtn').show();
                  var i = 60;
                  comm.flag1=false
                  var inter = setInterval(function() {
                      i--;
                      $('.un-ybtn').html('重新发送(' + i + ')');
                  },
                  1000);
                  setTimeout(function() {
                      clearInterval(inter);
                      $('.ybtn').show();
                      $('.un-ybtn').hide();
                      comm.flag1=true;
                  },
                  60000);
              } else if(data.code=-4){
                  comm.tips(data.msg);
                  comm.getPic();
              } else {
                  comm.tips(data.msg);
              }

          },
          error: function() {
              comm.tips('网络不佳，请稍后重试');
          }
      });
  },
</code></pre><p><!-- raw HTML omitted --> <!-- raw HTML omitted --></p>
<h2 id="资源">资源</h2>
<p><a href="">项目源码</a></p>

    </div>

    <div class="post-copyright">
  <p class="copyright-item">
    <span class="item-title">文章作者</span>
    <span class="item-content">wazan</span>
  </p>
  <p class="copyright-item">
    <span class="item-title">上次更新</span>
    <span class="item-content">
        2020-06-29
        
    </span>
  </p>
  
  
</div>
<footer class="post-footer">
      <div class="post-tags">
          <a href="/blog/tags/%E9%A1%B9%E7%9B%AE%E6%80%BB%E7%BB%93/">项目总结</a>
          </div>
      <nav class="post-nav">
        <a class="prev" href="/blog/post/t-%E7%BF%BB%E7%89%8C%E6%8A%BD%E5%A5%96/">
            <i class="iconfont icon-left"></i>
            <span class="prev-text nav-default">翻牌抽奖</span>
            <span class="prev-text nav-mobile">上一篇</span>
          </a>
        <a class="next" href="/blog/post/npm%E7%9B%B8%E5%85%B3/">
            <span class="next-text nav-default">npm相关</span>
            <span class="next-text nav-mobile">下一篇</span>
            <i class="iconfont icon-right"></i>
          </a>
      </nav>
    </footer>
  </article>
        </div>
        

  

  

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
      <a href="mailto:your@email.com" class="iconfont icon-email" title="email"></a>
      <a href="http://localhost:1313" class="iconfont icon-github" title="github"></a>
      <a href="http://localhost:1313" class="iconfont icon-zhihu" title="zhihu"></a>
  <a href="http://wazan.gitee.io/blog/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>

<div class="copyright">
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 - 
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>

  

  <span class="copyright-year">
    &copy; 
    2019 - 
    2020
    <span class="heart">
      <i class="iconfont icon-heart"></i>
    </span>
    <span class="author">wazan</span>
  </span>
</div>
    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  <script src="/blog/lib/highlight/highlight.pack.js?v=20171001"></script>
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>



<script type="text/javascript" src="/blog/js/main.min.d7b7ada643c9c1a983026e177f141f7363b4640d619caf01d8831a6718cd44ea.js"></script>








</body>
</html>
